草庐IT

C++ 11:std::thread池化?

全部标签

使用 std::atomic 的 C++ 线程安全增量,带模而不带互斥锁

我需要一个以循环方式使用的线程安全缓冲区对象池。我通常会在其中放置一个互斥锁以使增量和模线程安全,但是是否可以使用std::atomic来编写它?这是一个示例界面。如果它使事情变得更容易,缓冲区的总数可以是2的幂。永远不会在类外访问下一个缓冲区索引。classBuffer;classBufferManager{public:BufferManager(size_ttotalBuffers=8):mNextBufferIndex(0),mTotalBuffers(totalBuffers){mBuffers=newBuffer*[mTotalBuffers];}Buffer*GetNex

c++ - std::type_index 跨 DLL 是否安全

假设我有一个主DLL,其中有一个这样的类:classTest{public:typedefstd::unordered_mapMap;templatevoidSetValue(intval){SetValue(std::type_index(typeid(T)),val);}templateintGetValue(){returnGetValue(std::type_index(typeid(T)));}protected://Definedin.cppfilevoidSetValue(conststd::type_index&idx,intval){m_Map[idx]=val;}/

c++ - std::unique_ptr 使用带有少量参数的自定义删除器

我想知道是否可以使用多个参数(标准删除器签名)为std::unique_ptr指定自定义删除器。我知道std::shared_ptr存在std::bind的解决方法,这使得它成为可能但是std::unique_ptr存在一些技巧吗?对我来说似乎不是因为根据http://en.cppreference.com/w/cpp/memory/unique_ptr:Typerequirements-DeletermustbeFunctionObjectorlvaluereferencetoaFunctionObjectorlvaluereferencetofunction,callablewit

c++ - std::map 通过变换替换现有元素

我有一个代码:std::vectorvector={1,3,5,7,9};usingmy_type=std::pair;std::map>map;for(constauto&i:vector){map[i]=boost::none;}constmy_typeval={1,5};std::transform(vector.cbegin(),vector.cend(),std::inserter(map,map.end()),[&val](constint&i){returnstd::make_pair(i,boost::optional(val));});一切正常,但std::trans

2023.11.9 IDEA 配置 Lombok

目录什么是Lombok如何使用Lombok Lombok的@Data注解Lombok注释说明什么是LombokLombok是一个Java库,能自动插入编译器并构建工具,简化Java开发它通过注解实现这一目的,可用来帮助开发人员消除Java的冗长代码,尤其是对于简单的Java对象Lombok可以自动生成getter、setter、equals、hashCode、toString等方法,还可以自动生成构造函数等方法,从而减少了代码量如何使用Lombok 1.在maven项目的pom.xml文件中添加依赖org.projectlomboklombok1.18.24provided2.在实体类上使用L

c++ - 为什么在抛出 'std::bad_alloc' 实例后调用终止?

每1秒,函数工作一次。我的系统是linux。奔跑突然死亡。-----global-------staticintarrayNum[33000];-------------------function(){unsignedshortint**US_INT;US_INT=newunsignedshortint*[255];for(inti=0;i程序停止。和留言↓在抛出“std::bad_alloc”的实例后终止调用what():std::bad_alloc 最佳答案 bad_alloc异常是由内存分配失败触发的(因此您的new之一)。

c++ - 同时支持C++98和C++11

我开始重写大量必须适用于多种操作系统/编译器组合的代码。有些支持C++11,有些只支持C++98/C++03。我正在寻找一种能够在代码中使用一些C++11功能的方法。我主要感兴趣的是override、noexcept和final。换句话说,实际上没有C++98/03等效项的语法小功能。我并没有像What'stheC++98equivalentoftheautoiteratorreference?中那样使用ifdef尝试在范围for循环中硬塞进.这太笨拙了。我最初的想法是使用预处理器来做这样的事情:#if__cplusplus>201103L#defineOVERRIDEoverride

c++ - 如何将类型约束和隐式转换与 C++11 通用引用相结合?

在函数中我需要区分左值和右值引用,所以显而易见的路径是重载:voidmyfunc(A&&a);voidmyfunc(constA&a);这完全符合预期的行为,具有明确定义的类型和隐式转换。但是代码重复太多,我更愿意将相关的决定封装在里面,只保留一个函数,因此通过通用引用传递可能是一种选择:templatevoidmyfunc(A&&a);然而,这有一个不幸的缺点,即现在任何对象都可以作为第一个参数传递,因此可以通过enable_if施加约束:template::type>::type,A>::value,T>::type>voidmyfunc(T&&a);这似乎几乎可以完成工作,但是(

c++ - C++11 中的可变参数模板和多重继承

我正在努力实现这样的目标:我有一个模板化的基类,我想动态继承它templateclassfooBase{public:fooBase(){};~fooBase(){};};期望的方法:(像这样,不太确定该怎么做)templateclassfoo:publicInterfaces...{public:foo();~foo();}我的目标是让foo类像这样:第二种方法:classfoo():publicfooBase,publicfooBase,publicfooBase//andthelistcouldgoon{foo();~foo();}使用第二种方法的问题是,如果我实例化一个foo对

c++ - 将 std::bitset 分成两半?

我正在实现DES算法,我需要拆分std::bitsetpermutationKey分成两半。std::bitsetpermutationKey(0x133457799BBCDF);std::bitsetleftKey;std::bitsetrightKey;std::bitsetdivider(0b00000000000000000000000000001111111111111111111111111111);rightKey=permutationKey÷r;leftKey=(permutationKey>>28)÷r;我试着打字bitset至bitset但